package doxygenxml.compound;
 
/**********************************************************************************************
 * Copyright (c) 2001-2020 Liquid Technologies Limited. All rights reserved.
 * See www.liquid-technologies.com for product details.
 *
 * Please see products End User License Agreement for distribution permissions.
 *
 * WARNING: THIS FILE IS GENERATED
 * Changes made outside of ##HAND_CODED_BLOCK_START blocks will be overwritten
 *
 * Generation  :  by Liquid XML Data Binder 18.0.5.9988
 * Using Schema: CENSORED
 **********************************************************************************************/
	
// <summary>
// This class represents the ComplexType incType
// </summary>
public class IncType extends com.liquid_technologies.ltxmllib18.XmlGeneratedClass {
	private static final long serialVersionUID = 13L;

	// <summary>
	// 	Constructor for IncType
	// </summary>
	// <remarks>
	// The class is created with all the mandatory fields populated with the
	// default data. 
	// All Collection object are created.
	// However any 1-n relationships (these are represented as collections) are
	// empty. To comply with the schema these must be populated before the xml
	// obtained from ToXml is valid against the schema CENSORED
	// </remarks>
	public IncType() {
		setElementName("incType");
		init();
	}
	public IncType(String elementName) {
		setElementName(elementName);
		init();
	}		

	// <summary>
	// 	Initializes the class
	// </summary>
	// <remarks>
	// This creates all the mandatory fields (populated with the default data) 
	// All Collection object are created.
	// However any 1-n relationships (these are represented as collections) are
	// empty. To comply with the schema these must be populated before the xml
	// obtained from ToXml is valid against the schema CENSORED.
	// </remarks>
	@Override
	protected void init() {
		try {
			doxygenxml.compound.Registration.iRegistrationIndicator = 0; // causes registration to take place
			_refid = "";
			_isValidRefid = false;
			_local = doxygenxml.compound.DoxBool.Yes;
			_isValidLocal = false;

			_primitiveValue = "";
			// ##HAND_CODED_BLOCK_START ID="Additional Inits"## DO NOT MODIFY ANYTHING OUTSIDE OF THESE TAGS
			// Add Additional initialization code here...
			// ##HAND_CODED_BLOCK_END ID="Additional Inits"## DO NOT MODIFY ANYTHING OUTSIDE OF THESE TAGS

			getClassAttributeInfo();
			getClassElementInfo();
		} catch (Exception ex) {
			// should never happen
			ex.printStackTrace();
			throw new InternalError();
		}
	}



	// <summary>
	// Allows the class to be copied
	// </summary>
	// <remarks>
	// Performs a 'deep copy' of all the data in the class (and its children)
	// </remarks>
	@Override
	public Object clone() throws CloneNotSupportedException {
		try {
			doxygenxml.compound.IncType newObject = (doxygenxml.compound.IncType)super.clone();

			// clone, creates a bitwise copy of the class, so all the collections are the
			// same as the parents. Init will re-create our own collections, and classes, 
			// preventing objects being shared between the new an original objects
			newObject.init();
			if (_isValidRefid)
				newObject._refid = _refid;
			newObject._isValidRefid = _isValidRefid;
			newObject._local = _local;
			newObject._isValidLocal = _isValidLocal;
	
			newObject._primitiveValue = _primitiveValue;
// ##HAND_CODED_BLOCK_START ID="Additional clone"## DO NOT MODIFY ANYTHING OUTSIDE OF THESE TAGS

// Add Additional clone code here...

// ##HAND_CODED_BLOCK_END ID="Additional clone"## DO NOT MODIFY ANYTHING OUTSIDE OF THESE TAGS

			return newObject;
		} catch (CloneNotSupportedException e) {
			// should never happen
			e.printStackTrace();
			throw new InternalError();
		}
	}

	@Override
	public String getTargetNamespace() {
		return "";
	}

	// <summary>
	// Represents an optional Attribute in the XML document
	// </summary>
	// <remarks>
	// This property is represented as an Attribute in the XML.
	// It is optional, initially it is not valid.
	// </remarks>
	public java.lang.String getRefid() throws com.liquid_technologies.ltxmllib18.exceptions.LtException { 
		if (_isValidRefid == false)
			throw new com.liquid_technologies.ltxmllib18.exceptions.LtInvalidStateException("The Property refid is not valid. Set refidValid = true");
		return _refid;  
	}
	public void setRefid(java.lang.String value) throws com.liquid_technologies.ltxmllib18.exceptions.LtException { 
		// Apply whitespace rules appropriately
		value = com.liquid_technologies.ltxmllib18.WhitespaceUtils.preserve(value); 
		_isValidRefid = true;
		_refid = value;
	}

	// <summary>
	// Indicates if refid contains a valid value.
	// </summary>
	// <remarks>
	// true if the value for refid is valid, false if not.
	// If this is set to true then the property is considered valid, and assigned its
	// default value ("").
	// If its set to false then its made invalid, and subsequent calls to get refid
	// will raise an exception.
	// </remarks>
	public boolean isValidRefid() {
		return _isValidRefid;
	}
	public void setValidRefid(boolean value)  throws com.liquid_technologies.ltxmllib18.exceptions.LtException { 
		if (value != _isValidRefid) {
			_refid = "";
			_isValidRefid = value;
		}
	}
	protected boolean _isValidRefid;
	protected java.lang.String _refid;

	// <summary>
	// Represents an optional Attribute in the XML document
	// </summary>
	// <remarks>
	// This property is represented as an Attribute in the XML.
	// It is optional, initially it is not valid.
	// </remarks>
	public doxygenxml.compound.DoxBool getLocal() throws com.liquid_technologies.ltxmllib18.exceptions.LtException {
		if (_isValidLocal == false)
			throw new com.liquid_technologies.ltxmllib18.exceptions.LtInvalidStateException("The Property local is not valid. Set localValid = true");
		return _local;
	}
	public void setLocal(doxygenxml.compound.DoxBool value) throws com.liquid_technologies.ltxmllib18.exceptions.LtException { 
		_local = value;
		_isValidLocal = true;
	}
	// <summary>
	// Indicates if local contains a valid value.
	// </summary>
	// <remarks>
	// true if the value for local is valid, false if not.
	// If this is set to true then the property is considered valid, and assigned its
	// default value (doxygenxml.compound.DoxBool.Yes).
	// If its set to false then its made invalid, and subsequent calls to get local
	// will raise an exception.
	// </remarks>
	public boolean isValidLocal() {
		return _isValidLocal;  
	}
	public void setValidLocal(boolean value) throws com.liquid_technologies.ltxmllib18.exceptions.LtException { 
		if (value != _isValidLocal) {
			_local = doxygenxml.compound.DoxBool.Yes;
			_isValidLocal = value;
		}
	}
	protected doxygenxml.compound.DoxBool _local;
	protected boolean _isValidLocal;

	// <summary>
	// The InnerText for this element
	// </summary>
	// <remarks>
	// This class represents the element IncType, this
	// element is open, and as such we can place data into it.
	// i.e. <IncType>Some Data</IncType>
	// </remarks>
	public java.lang.String getPrimitiveValue() {
		return _primitiveValue;
	}
	public void setPrimitiveValue(java.lang.String value) {
		_primitiveValue = com.liquid_technologies.ltxmllib18.WhitespaceUtils.preserve(value);
	}
	protected java.lang.String _primitiveValue;

	@Override
	public String getNamespace() {
		return "";
	}	

	@Override
	public com.liquid_technologies.ltxmllib18.XmlObjectBase getBase() {
		return this;
	}
	protected void onEvent(com.liquid_technologies.ltxmllib18.XmlObjectBase msgSource, int msgType, Object data) {
		if (msgType == CollectionChangeEvent) {
		}
	}

	private static com.liquid_technologies.ltxmllib18.ParentElementInfo __parentElementInfo = null;
	private static com.liquid_technologies.ltxmllib18.ElementInfo[] __elementInfo = null;
	private static com.liquid_technologies.ltxmllib18.AttributeInfo[] __attributeInfo = null;
		
	protected com.liquid_technologies.ltxmllib18.ParentElementInfo getClassInfo() throws Exception {
		if (__parentElementInfo == null) {
			__parentElementInfo = new com.liquid_technologies.ltxmllib18.ParentElementInfo(	
																	com.liquid_technologies.ltxmllib18.XmlObjectBase.XmlElementGroupType.SEQUENCE,
																	com.liquid_technologies.ltxmllib18.XmlObjectBase.XmlElementType.ELEMENT, "incType", "", true, false,
																	findGetterMethod("doxygenxml.compound.IncType", "getPrimitiveValue"), findSetterMethod("doxygenxml.compound.IncType", "setPrimitiveValue", "java.lang.String"),
																	com.liquid_technologies.ltxmllib18.Conversions.ConversionType.TYPE_STRING, null, false);
		}
		return __parentElementInfo;
	}

	protected com.liquid_technologies.ltxmllib18.ElementInfo[] getClassElementInfo() throws Exception {
		if (__elementInfo == null) {
			__elementInfo = new com.liquid_technologies.ltxmllib18.ElementInfo[] {
			};
		}
		return __elementInfo;
	}

	protected com.liquid_technologies.ltxmllib18.AttributeInfo[] getClassAttributeInfo() throws Exception {
		if (__attributeInfo==null) {
			__attributeInfo = new com.liquid_technologies.ltxmllib18.AttributeInfo[] {
				 new com.liquid_technologies.ltxmllib18.AttributeInfoPrimitive("refid", "", findGetterMethod("doxygenxml.compound.IncType", "getRefid"), findSetterMethod("doxygenxml.compound.IncType", "setRefid", "java.lang.String"), findGetterMethod("doxygenxml.compound.IncType", "isValidRefid"), com.liquid_technologies.ltxmllib18.Conversions.ConversionType.TYPE_STRING, null, com.liquid_technologies.ltxmllib18.WhitespaceRule.PRESERVE, new com.liquid_technologies.ltxmllib18.PrimitiveRestrictions("", -1, -1, "", "", "", "", -1, -1, -1), null)
				,new com.liquid_technologies.ltxmllib18.data.AttributeInfoEnum("local", "", findGetterMethod("doxygenxml.compound.IncType", "getLocal"), findSetterMethod("doxygenxml.compound.IncType", "setLocal", "doxygenxml.compound.DoxBool"), findGetterMethod("doxygenxml.compound.IncType", "isValidLocal"), getEnumFromString("doxygenxml.compound.DoxBool", "DoxBool"), getEnumToString("doxygenxml.compound.DoxBool", "DoxBool"), null)
			};
		}
		return __attributeInfo;
	}

// ##HAND_CODED_BLOCK_START ID="Additional Methods"## DO NOT MODIFY ANYTHING OUTSIDE OF THESE TAGS

// Add Additional Methods and members here...

// ##HAND_CODED_BLOCK_END ID="Additional Methods"## DO NOT MODIFY ANYTHING OUTSIDE OF THESE TAGS
}


